2

11

12

13

## **CLAIMS**

- 1. A system configured to provide fast acknowledgement and efficient servicing of an 1 interrupt issued to a processor of an intermediate node, the system comprising:
- an external device coupled to a high latency path, the external device generating a 3
- pulsed interrupt signal for each type of interrupt supported by the processor; 4
- an interrupt multiplexing device accessible by the processor over a fast bus, the 5
- interrupt multiplexing device adapted to issue the interrupt to the processor in response to 6
- each pulsed interrupt signal generated by the external device; 7
- a low latency path coupling the external device to the interrupt multiplexing de-8
- vice and adapted to transport each pulsed interrupt signal generated by the external de-9
- vice to the interrupt multiplexing device; and 10
  - a status bit stored within the interrupt multiplexing device, the status bit adapted for assertion whenever the pulsed interrupt signal is detected at the interrupt multiplexing device,
- wherein the processor efficiently acknowledges the issued interrupt by accessing 14 the interrupt multiplexing device over the fast bus. 15
- 2. The system of Claim 1 further comprising a current counter associated with the inter-1
- rupt multiplexing device, the current counter incremented in response to each pulsed in-2
- terrupt signal at the interrupt multiplexing device. 3
- 3. The system of Claim 2 further comprising an interrupt handler invoked by the proces-1
- sor to service the issued interrupt. 2
- 4. The system of Claim 3 further comprising a last counter associated with the processor, 1
- the last counter incremented in response to each interrupt serviced by the CPU. 2

- 5. The system of Claim 4 further comprising means for comparing a value of the last
- 2 counter with a value of the current counter to determine whether there are more interrupts
- 3 to service.
- 6. The system of Claim 5 wherein the means for comparing comprises the interrupt han-
- 2 dler.
- 7. The system of Claim 1 wherein the external device is a direct memory access con-
- 2 troller.
- 8. The system of Claim 1 wherein the low latency path is a printed circuit board trace.
- 9. The system of Claim 1 wherein the high latency path is a peripheral computer inter-
- 2 connect bus.
- 1 10. The system of Claim 1 wherein the interrupt multiplexing device is a field program-
- 2 mable gate array device.
- 1 11. A method for providing fast acknowledgement and efficient servicing of an interrupt
- 2 issued to a processor of an intermediate node, the method comprising the steps of:
- generating a pulsed interrupt signal at an external device coupled to a high latency
- 4 path;
- transporting the pulsed interrupt signal to an interrupt multiplexing device over a
- 6 low latency path coupling the external device to the interrupt multiplexing device;
- asserting a status bit in response to detecting the pulsed interrupt signal at the in-
- 8 terrupt multiplexing device;
- issuing the interrupt to the processor in response to each pulsed interrupt signal
- received at the interrupt multiplexing device; and
- invoking an interrupt handler to service the issued interrupt.

- 1 12. The method of Claim 11 further comprising the step of initializing a last counter.
- 1 13. The method of Claim 12 further comprising the steps of:
- 2 reading the status bit; and
- if the status bit is clear, dismissing the handler.
- 14. The method of Claim 13 wherein the step of reading further comprises the step of
- 2 clearing the status bit.
- 1 15. The method of Claim 13 further comprising the steps of:
- if the status bit is set, reading a value of a current counter;
- comparing the current counter value with a value of the last counter; and
- if the last counter value is greater than or equal to the current counter value, re-
- turning to the step of reading the status bit.
- 1 16. The method of Claim 15 further comprising the steps of:
- if the last counter value is not greater than or equal to the current counter value,
- checking a control block stored in a memory of the node, the control block shared be-
- 4 tween the processor and the external device; and
- 5 determining whether the processor owns the control block.
- 17. The method of Claim 16 further comprising the steps of:
- if the processor owns the control block, processing the control block; and
- incrementing the last counter.
- 1 18. The method of Claim 17 further comprising the steps of:
- determining whether a preset limit for processing control blocks has been
- 3 reached; and
- if the preset limit is reached, dismissing the handler.

13

| 1  | 19. Apparatus for providing fast acknowledgement and efficient servicing of an inter-     |
|----|-------------------------------------------------------------------------------------------|
| 2  | rupt issued to a processor of an intermediate node, the apparatus comprising:             |
| 3  | means for generating a pulsed interrupt signal at an external device coupled to a         |
| 4  | high latency path;                                                                        |
| 5  | means for transporting the pulsed interrupt signal to an interrupt multiplexing de-       |
| 6  | vice over a low latency path coupling the external device to the interrupt multiplexing   |
| 7  | device;                                                                                   |
| 8  | means for asserting a status bit in response to detecting the pulsed interrupt signal     |
| 9  | at the interrupt multiplexing device;                                                     |
| 10 | means for issuing the interrupt to the processor in response to each pulsed inter-        |
| 11 | rupt signal received at the interrupt multiplexing device; and                            |
| 12 | means for invoking an interrupt handler to service the issued interrupt.                  |
|    |                                                                                           |
| 1  | 20. A computer readable medium containing executable program instructions for pro-        |
| 2  | viding fast acknowledgement and efficient servicing of an interrupt issued to a processor |
| 3  | of an intermediate node, the executable program instructions comprising program in-       |
| 4  | structions for:                                                                           |
| 5  | generating a pulsed interrupt signal at an external device coupled to a high latency      |
| 6  | path;                                                                                     |
| 7  | transporting the pulsed interrupt signal to an interrupt multiplexing device over a       |
| 8  | low latency path coupling the external device to the interrupt multiplexing device;       |
| 9  | asserting a status bit in response to detecting the pulsed interrupt signal at the in-    |
| 10 | terrupt multiplexing device;                                                              |
| 11 | issuing the interrupt to the processor in response to each pulsed interrupt signal        |
| 12 | received at the interrupt multiplexing device; and                                        |

invoking an interrupt handler to service the issued interrupt.